package com.techsoul.module.goods.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.techsoul.module.goods.pojo.entity.SpecParamTemplate;
import com.techsoul.module.goods.pojo.param.SpecParamTemplateSearchParam;
import com.techsoul.module.goods.pojo.vo.SpecParamTemplateVo;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Update;

import java.util.List;

/**
 * 规格参数模板Mapper接口
 * 
 * @author liuen
 * @date 2020-12-07
 */
public interface SpecParamTemplateMapper extends BaseMapper<SpecParamTemplate> {

    /**
     * 更新规格数量
     * @return
     */
    @Update("UPDATE pms_spec_param_template SET spec_qty = (SELECT COUNT(*) FROM pms_spec WHERE template_id = #{id}) WHERE id = #{id}")
    void updateSpecQty(String id);

    /**
     * 更新参数数量
     * @return
     */
    @Update("UPDATE pms_spec_param_template SET param_qty = (SELECT COUNT(*) FROM pms_param WHERE template_id = #{id}) WHERE id = #{id}")
    void updateParamQty(String id);

    /**
     * 详情
     * @param id
     * @return
     */
    SpecParamTemplateVo findById(String id);

    /**
     * 列表
     * @param params
     * @return
     */
    List<SpecParamTemplateVo> findAll(@Param("params") SpecParamTemplateSearchParam params);

    /**
     * 分页
     * @param page
     * @param params
     * @return
     */
    IPage<SpecParamTemplateVo> findAll(Page page, @Param("params") SpecParamTemplateSearchParam params);

}
